package com.xuenci.gulimall.coupon;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

/**
 * 1、如何使用Nacos作为配置中心统一管理
 *      1）、引入依赖
 *         <dependency>
 *             <groupId>com.alibaba.cloud</groupId>
 *             <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
 *         </dependency>
 *      2）、创建一个bootstrap.properties。
 *         spring.application.name=gulimall-coupon
 *         spring.cloud.nacos.config.server-addr=127.0.0.1:8848
 *      3）、需要给配置中心默认添加一个叫数据集（Data ID）gulimall-coupon.properties。默认规则，应用名.properties
 *      4）、给 应用名.properties 添加任何配置
 *      5）、动态获取配置
 *          @RefreshScope ： nacos配置中心动态刷新数据源
 *          @Value("${配置项的名}")
 *          如果配置中心和当前应用的配置文件中都配置了相同的项。休闲使用配置中心的配置。
 *
 *  2、细节
 *      1）、命名空间：配置隔离
 *          默认：public（保留空间）：默认新增的所有配置都在public空间。
 *   ​	    1.开发、测试、生产:利用命名空间来做环境隔离
 *              注意：在 bootstrap.properties 配置上，需要使用那个命名空间下的配置，
 * ​			    spring.cloud.nacos.config.namespace=4b96c84c-e8cf-4f8c-b87c-63fca0cf08ec（命名空间名字后面的id）
 *          2.每一个微服务之间相互隔离配置，每一个微服务都创建自己的命名空间，只加载自己的命名空间下的所有配置
 *      2)、配置集
 *          所有配置的集合
 *      3)、配置集ID:类似于文件名
 *          Data Id
 *      4)、配置分组:
 *          默认所有的配置集都属于：DEFAULT_GROUP
 * 每个微服务创建自己的命名空间，使用配置分组区分环境。Dev、test、prod
 *
 * 3、同时加载多个配置集
 *      1）、微服务任何配置信息，任何配置文件都可以放在配置中心中
 *      2）、只需要在bootstrap.properties 说明加载配置中心中那些配置文件即可
 *      3）、@Value，@ConfigurationProperties。。。
 * 以前SpringBoot任何方法从配置文件中获得取值，都能使用。
 * 配置中心有的 优先使用配置中心的。
 */

@EnableDiscoveryClient
@SpringBootApplication
public class GulimallCouponApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallCouponApplication.class, args);
    }

}
